package com.briup.mt.web.controller;

import com.briup.mt.bean.BaseRole;
import com.briup.mt.service.IBaseRoleService;
import com.briup.mt.utils.ExcelUtils;
import com.briup.mt.utils.Message;
import com.briup.mt.utils.MessageUtil;
import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiImplicitParams;
import io.swagger.annotations.ApiOperation;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*;

import javax.servlet.http.HttpServletResponse;
import javax.validation.constraints.NotNull;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

@RestController
@Validated
@RequestMapping("/baseRole")
public class BaseRoleServiceController {

    @Autowired
    private IBaseRoleService baseRoleService;

    @ApiOperation(value = "导入到Excel中", notes = "注意！测试的时候请将地址粘贴到浏览器地址栏测试", produces = "baseRole/octet-stream")
    @GetMapping("download")
    @ApiImplicitParams({
            @ApiImplicitParam(name = "name", value = "角色名", paramType = "query"), })
    public void download(HttpServletResponse response,String name) throws Exception {
        // 2. 将excel导出
        // 2.1 excel头部数据
        String[] headList = new String[] { "角色名"};
        // 2.2 属性77
        String[] fieldList = new String[] { "name" };
        // 2.3 数据列，需要转化
        List<Map<String, Object>> dataList = new ArrayList<>();
        List<BaseRole> list = baseRoleService.query(name);
        for (BaseRole role : list) {
            Map<String, Object> map = new HashMap<>();
            map.put("name", role.getName());
            dataList.add(map);
        }
        // 2.4 导出文件名
        String excelName = "Baserole";
        // 3. 调用工具方法导出Excel
        ExcelUtils.createExcel(response, excelName, headList, fieldList, dataList);
    }

    @GetMapping("query")
    public Message query(String name){
        List<BaseRole> list = baseRoleService.query(name);
        return MessageUtil.success(list);
    }
    @PostMapping("saveOrUpdate")
    public Message saveOrUpdate(BaseRole role){
        baseRoleService.saveOrUpdate(role);
        return MessageUtil.success("操作成功");
    }

    @DeleteMapping("deleteById")
    @ApiImplicitParams({
            @ApiImplicitParam(name = "id", value = "用户编号", required = true, paramType = "query"),

    })
    public Message deleteById( @NotNull Long id){
        baseRoleService.deteleById(id);
        return MessageUtil.success("操作成功");
    }

}
